# **INTEGRATED CIRCUITS**



Preliminary specification File under Integrated Circuits, IC20 1997 Jul 02



## **CONTENTS**



8 PURCHASE OF PHILIPS I<sup>2</sup>C COMPONENTS



## <span id="page-2-0"></span>**1 FEATURES**

- Full static 80C51 CPU (8-bit CPU) with a minimum 6 clocks per instruction
- OTP/ROM program memory
- RAM, expandable externally to 64 kbytes (only on certain devices)
- DTMF generator
- MSK modem including Manchester encoder/decoder for analog cordless telephones (standards CT0/CT1/CT1+)
- Pulse Width Modulated output (8-bit resolution)
- EEPROM data memory, accessed internally via I<sup>2</sup>C-bus interface
- 8-bit ports, I/O lines
- Three 16-bit timer/event counters, including one with capture, compare and PWM function
- Watchdog Timer
- External memory expandable up to 128 kbytes external ROM up to 64 kbytes and/or RAM up to 64 kbytes (only possible on certain devices)
- On-chip amplitude controlled oscillator (ACO) suitable for quartz crystal or ceramic resonator
- 32 kHz Real-Time Clock (RTC) with programmable interrupt periods
- Twenty source, twenty vector interrupt structure with two priority levels
- Full duplex enhanced UART with double buffering
- I 2C-bus interface for 2-wire serial transfer, 400 kHz maximum
- Enhanced architecture with:
	- Non-page oriented instructions
	- Direct addressing
	- Four 8 byte RAM register banks
	- Stack depth limited only by available internal RAM (maximum 256 bytes)
	- Multiply, divide, subtract and compare instructions
- Eight additional interrupts on Port 1
	- Edge or level sensitive triggering selectable via software
	- Power-saving use for keyboard control.
- Improved Power-on/Power-off reset circuitry (POR) with 9 hardware programmable levels
- Low Voltage Detection (LVD) with 11 software programmable levels
- Wake-up from Power-down mode via external interrupts at Port 1, via RTC or via LVD
- Very low current consumption.

## **2 GENERAL DESCRIPTION**

The TELX microcontroller family is manufactured in an advanced CMOS technology and is based on MCM (Multi-Chip-Module) technology as the non-volatile memory parts OTP and EEPROM are integrated on a separate chip.

The TELX family are 8-bit microcontrollers especially suited for analog cordless telephones (CT0, CT1, CT1+ standards), mid/high-end corded telephones and pagers. For this purpose, features like DTMF, EEPROM, MSK modem, PWM, POR/LVD, ACO and RTC are integrated on-chip. The device is optimized for low power consumption. The TELX family has two software selectable features for power reduction: Idle and Power-down modes.

The instruction set of the TELX family is based on that of the 8051. The TELX family also functions as an arithmetic processor having facilities for both binary and BCD arithmetic plus bit-handling capabilities. The instruction set consists of over 100 instructions: 49 one-byte, 46 two-byte, and 16 three-byte.

This data sheet details the shared properties of the TELX family. For a particular microcontroller, read this data sheet in conjunction with the individual data sheet of the specific device. For details on the I<sup>2</sup>C-bus functions see "Data Handbook IC12".

Philips Semiconductors Philips Semiconductors Preliminary specification

# Low voltage 8-bit microcontrollers TELX family Low voltage 8-bit microcontrollers

TELX family

<span id="page-3-0"></span>

 $\blacktriangle$ 

Preliminary specification

## <span id="page-4-0"></span>**4 FUNCTIONAL DESCRIPTION**

## **4.1 General**

The TELX family provides stand-alone high-performance CMOS microcontrollers designed for use in mid/high-end corded telephones, analog cordless telephones (CT0, CT1, CT1+ standards) and pagers. For this purpose, features such as DTMF, MSK modem, EEPROM, Real-Time-Clock and PWM have been integrated on-chip. The devices provide hardware features, architectural enhancements and new instructions to function as a controller for applications requiring up to 64 kbytes of program memory and/or up to 64 kbytes of data storage.

The TELX family contains ROM or OTP program memory; a static read/write data memory; I/O lines; three 16-bit timer/event counters; a twenty-source two priority-level, nested interrupt structure and on-chip oscillator and timing circuit.

The TELX devices have two software selectable modes of reduced activity for power reduction: Idle and Power-down. The Idle mode freezes the CPU while allowing the RAM, timers, serial I/O and interrupt system to continue functioning. The Power-down mode saves the RAM contents but freezes the oscillator causing all other chip functions to be inoperative.

Two serial interfaces are provided on-chip; a standard UART serial interface and an I2C-bus serial interface. The I<sup>2</sup>C-bus serial interface has byte orientated master and slave functions allowing communication with the whole family of I<sup>2</sup>C-bus compatible devices.

## **4.2 CPU timing**

A machine cycle consists of a sequence of 6 states. Each state lasts for one oscillator period, thus a machine cycle takes 6 oscillator periods or e.g. 1.68 µs if the oscillator frequency is 3.58 MHz. This means that the TELX family is twice as fast as a standard 80C51 based on the same oscillator frequency.

## **4.3 Clocking concept with prescaler PSC**

The clocking concept of the TELX family is shown in Fig.2. The on-chip oscillator directly clocks the CPU (including timers T0 and T1), timer T2, PWM, the Watchdog Timer and the Analog-to-Digital Converter (ADC).

The DTMF block requires an input frequency of 3.58 MHz for correct operation. For this purpose a prescaler (PSC) has been included to enable multiples of 3.58 MHz to be used as the oscillator frequency. The blocks I<sup>2</sup>C-bus, UART special purpose baud rate generator, MSK modem, Watchdog Timer and EEPROM are also clocked via the PSC prescaler to minimize the number of prescalers on-chip and thereby reducing the power consumption. The division factors 1:1 through to 1:8 of the PSC prescaler are software programmable via the PRESC register, see Tables 2 and 3. The PSC division factor should only be set in the initialization routine directly after start-up. The prescaler and the special baud rate timer for the UART are described in Section 4.13.

In order to minimize power consumption, the individual blocks automatically switch-off their clock (gated clock) when they are not enabled.



## 4.3.1 PRESCALER REGISTER (PRESC)

**Table 1** Prescaler Register (SFR address F3H)



## **Table 2** Description of PRESC bits



## **Table 3** Selection of PSC division factors



The oscillator is controlled by the RUN bit in the Clock

The divider chain operates with the 32 kHz oscillator output and divides this signal down to two clocks with a period of 1, 2 or 4 seconds or 1 minute respectively. Depending on the state of the ITS1 and ITS0 bits in the Clock Control Register, the falling edge of the seconds or minutes clock is used to set the Clock Interrupt Flag (CIF)

Additionally, the divider chain generates a 16 kHz clock (RTCLK) that can be routed through the port line P1.3/RTCLK, controlled by the ERCO bit in the Clock

Frequency adjustment is used to extend the interrupt time by defining the number of 16 kHz clocks in the Frequency Adjustment Register (FAR) that will be counted twice within the first second period after a minute interrupt.

Control Register.

Control Register.

in the Clock Control Register.

## <span id="page-6-0"></span>**4.4 32 kHz Real-Time Clock**

The Real-Time Clock (RTC) consists of a 32 kHz crystal oscillator, a 32 kHz to 1 second or 1 minute divider chain, an 8-bit Frequency Adjustment Register (FAR) and the Clock Control Register (CLCR). The complete RTC section works independent of the microcontroller status, even in Idle and Power-down mode.

The RTC can generate an interrupt periodically every 1 minute or every 1, 2 or 4 seconds. This interrupt can be used to wake-up the microcontroller from the Power-down mode without resetting it. This feature is especially useful in CT0/CT1 cordless phone applications to wake-up the microcontroller periodically to perform channel scanning.

The internal 32 kHz oscillator requires an external quartz crystal with a frequency of 32.768 kHz (a positive deviation up to +200 ppm is allowed) and an external feedback resistor connected between pins RTC1 and RTC2; 4.7  $M\Omega$  is recommended.

## 4.4.1 CLOCK CONTROL REGISTER (CLCR)

**Table 4** Clock Control Register (address ACH; access type R/W)



## **Table 5** Description of CLCR bits







### **Note**

1. If the 1 second interrupt is used, every 60<sup>th</sup> interval may be up to 15.3 ms longer than the others as a result of the frequency adjustment. The adjusted Minute Interrupt Time (MIT) shows now a maximum deviation of 0.5 ppm.

## 4.4.2 FREQUENCY ADJUSTMENT REGISTER (FAR)

The frequency adjustment value of the RTC section is defined by the 8-bit Frequency Adjustment Register. The register access type is R/W. The significance of the individual bits of the FAR register can be illustrated by the following equation:

$$
Minute interrupt time (MIT) = 60 \times 2^{\frac{14}{f_{RTCLK}}} + \frac{FAR}{2^{14}}
$$

where  $f_{\text{RTCLK}}$  = RTC frequency and FAR represents the decimal value of the contents of the Frequency Adjustment Register.

**Table 7** Frequency Adjustment Register (address ADH)

| FAR7 | FAR6 | FAR5 | FAR4 | FAR <sub>3</sub> | FAR <sub>2</sub> | FAR <sub>1</sub> | FAR <sub>0</sub> |
|------|------|------|------|------------------|------------------|------------------|------------------|

| <b>BIT</b>    | <b>SYMBOL</b>    | <b>DESCRIPTION</b>                                                                   |  |  |
|---------------|------------------|--------------------------------------------------------------------------------------|--|--|
| 7             | FAR7             | The state of these 8-bits determine the frequency adjustment value for the Real-Time |  |  |
| 6             | FAR <sub>6</sub> | Clock; see Table 9.                                                                  |  |  |
| 5             | FAR <sub>5</sub> |                                                                                      |  |  |
| 4             | FAR4             |                                                                                      |  |  |
| 3             | FAR <sub>3</sub> |                                                                                      |  |  |
| $\mathcal{P}$ | FAR <sub>2</sub> |                                                                                      |  |  |
|               | FAR1             |                                                                                      |  |  |
| 0             | FAR0             |                                                                                      |  |  |

**Table 8** Description of FAR bits

## **Table 9** Selection of FAR value based on f<sub>RTCLK</sub>

















## <span id="page-12-0"></span>**4.5 Memory organization**

The TELX family has Program Memory (OTP or ROM) plus Data Memory (RAM) on-chip. The device has separate address spaces for Program and Data Memory as shown in Fig.3. On devices with ports P0 and P2 available, up to 64 kbytes of external memory can be addressed. In this case, the CPU generates both read (RD) and write (WR) signals for external Data Memory accesses, and the read strobe (PSEN) for external Program Memory.

## 4.5.1 Program memory

After reset the CPU begins execution at location 0000H of the Program Memory. The Program Memory can be implemented in either internal OTP/ROM or external memory. If the EA pin is tied to  $V_{DD}$ , then program memory fetches are directed to the internal program memory. If the EA pin is tied to  $V_{SS}$  and if the security bits are not set, then program memory fetches are directed to external memory.

## 4.5.2 Data memory

The data memory organisation of the TELX family is exactly the same as for the P8xCE558. The TELX family contains a maximum of 512 bytes internal RAM (consisting of 256 bytes standard RAM and 256 bytes AUX-RAM) and Special Function Registers (SFRs). Figure 3 shows the internal Data Memory space divided into the lower 128 bytes, the upper 128 bytes, the SFR space and 256 bytes Auxiliary RAM. Internal RAM locations 0 to 127 are directly and indirectly addressable. Internal RAM locations 128 to 255 are only indirectly addressable. The SFRs locations 128 to 255 bytes are only directly addressable and the Auxiliary RAM is indirectly addressable as external RAM (MOVX) unless it is disabled by setting  $ARD = 1$ .

## 4.5.3 Special Function Registers

The second 128 bytes are the address locations of the SFRs. Figure 4 and Table 10 define the SFRs memory space. The SFRs include the port latches, timers, peripheral control, serial I/O registers, etc. These registers can only be accessed by direct addressing. There are 128 addressable locations in the SFR address space (those SFRs whose addresses are divisible by eight). Refer to the product specifications for the precise list of the SFRs implemented and their value directly after reset.

## **4.6 Addressing**

The TELX family has five methods for addressing source operands:

- Register
- Direct
- Register-Indirect
- Immediate
- Base-Register plus Index-Register-Indirect.

The first three methods can be used for addressing destination operands. Most instructions have a 'destination/source' field that specifies the data type, addressing methods and operands involved. For operations other than MOVs, the destination operand is also a source operand.

Access to memory addressing is as follows:

- Registers in one of the four 8-register banks through Register Direct or Register-Indirect
- A maximum of 1024 bytes of internal data RAM through Direct or Register-Indirect
	- Bytes 0 to 127 of internal RAM may be addressed directly or indirectly. Bytes 128 to 255 of internal RAM share their address location with the Special Function Registers and so may only be addressed indirectly as data RAM
	- Bytes 0 to 256 of AUX-RAM can only be addressed indirectly via MOVX instructions.
- Special Function Registers through Direct
- External data memory through Register-Indirect
- Program memory look-up tables through Base-Register plus Index-Register-Indirect.

The members of the TELX family are classified as 8-bit devices since their internal ROM, RAM, Special Function Registers, Arithmetic Logic Unit and external data bus are all 8-bits wide. All perform operations on bit, nibble, byte and double-byte data types.

Facilities are available for byte transfer, logic and integer arithmetic operations. Data transfer, logic and conditional branch operations can be performed directly on Boolean variables to provide excellent bit handling.







f,

# Philips Semiconductors Preliminary specification Preliminary specification

TELX family

# Low voltage 8-bit microcontrollers Low voltage 8-bit microcontrollers TELX family

## **Table 10** Special Function Register memory map (bit addressing)



20 Inr 2661

## <span id="page-16-0"></span>**4.7 I/O facilities**

## 4.7.1 PORTS

The TELX family has 32 I/O lines treated as 32 individually addressable bits or as four parallel 8-bit addressable ports. Ports 0 to 3 perform the following alternative functions.

Port 0 Provides the multiplexed low-order address and data bus for expanding the device with standard memories and peripherals.

Port 1 Used for a number of special functions:

- Provides the inputs for the external interrupts INT2 to INT9
- External inputs of Timer 2
- External activation and compare output of Timer 2
- Real-Time Clock output (16 kHz)
- DTMF melody output
- CLK/P1.4 for the clock output
- SCL/P1.6 and SDA/P1.7 for the I<sup>2</sup>C-bus interface are open-drain outputs.
- Port 2 Provides the high-order address bus when expanding the device with external program memory and/or external data memory.

Port 3 Pins can be configured individually to provide:

- Serial port receiver input and transmitter output (UART)
- External interrupt request inputs
- Counter inputs
- Control signals to read and write to external memories.

To enable a port pin alternative function, the port bit latch in its SFR must contain a logic 1.

Each port consists of a latch (SFRs P0 to P3), an output driver and input buffer. All ports have internal pull-ups. Figure 5(a) shows that the strong transistor p1 is turned on for only 1 oscillator period after a LOW-to-HIGH transition in the port latch. When on, it turns on p3 (a weak pull-up) through the inverter IN1. This inverter and p3 form a latch which holds the logic 1.

The Alternative Port Function Register (ALTP) is described in Section 4.10.4.

## 4.7.2 PORT I/O CONFIGURATION

I/O port output configurations are determined by the settings in the port configuration SFRs. Each port has two associated SFRs: PnCFGA and PnCFGB, where 'n' indicates the specific port number (0 to 3). One bit in each of the 2 SFRs relates to the output setting for the corresponding port pin, allowing any combination of the 2 output types to be mixed on those port pins. For example, the output type of Port 1 pin 3 is controlled by setting bit 3 in the SFRs P1CFGA and P1CFGB.

The port pins may be individually configured with one of the following modes (P1.6 and P1.7 can be open-drain or high-impedance but never have any diodes against  $V_{DD}$ ).

- Mode 0 Open-drain; quasi-bidirectional I/O with n-channel open-drain output. Use as an output (e.g. Port 0 for external memory accesses  $(EA = 0)$  or access above the built-in memory boundary) requires the connection of an external pull-up resistor. The ESD protection diodes against  $V_{DD}$  and  $V_{SS}$  are still present. Except for the  $1<sup>2</sup>C$ -bus port (P1.6 and P1.7), ports which are configured as open-drain still have a protection diode to  $V_{DD}$ . See Fig.5(a).
- Mode 1 Standard Port; quasi-bidirectional I/O with pull-up. The strong pull-up p1 is turned on for only two oscillator periods after a LOW-to-HIGH transition in the port latch. After these two oscillator periods the port is only weakly driven through p2 and 'very weakly' driven through p3. See Fig.5(b).
- Mode 2 High-impedance; this mode turns all port output drivers off. Thus, the pin will not source or sink current and may be used as an input-only pin with no internal drivers for an external device to overcome. See Fig.5(c).
- Mode 3 Push-pull; output with drive capability in both polarities. In this mode, pins can only be used as outputs. See Fig.5(d).

Tables 11 and 12 show the configuration register settings for the four output configurations.

The electrical characteristics of each output type may be found in the DC characteristics in the specific product data sheet.

The default port configuration after reset is also given in the specific product data sheet.



### **Table 11** Selection of the port output configuration

## **Note**

1. If P1CFGA.7 is set the I2C-bus interfaces of the microcontroller and other on-chip blocks with an I2C-bus interface (e.g. EEPROM) are connected internally. This means that the microcontroller can access these blocks via the I 2C-bus without using P1.6 and P1.7.



**Table 12** Special Function Registers for port configurations; note 1

### **Note**

1. Mode changes may cause glitches to occur during transitions. When modifying both registers, WRITE instructions should be carried out consecutively.



## <span id="page-19-0"></span>**4.8 Timer/event counters**

The TELX family contains three 16-bit timer/event counters: Timer 0, Timer 1 and Timer 2 which perform the following functions:

- Measure time intervals and pulse durations
- Count events
- Generate interrupt requests
- Generate output on comparator match
- Generate a pulse width modulated output signal.

Timer 0 and Timer 1 can be programmed independently to operate in four modes:

- Mode 0 8-bit timer or 8-bit counter each with divide-by-32 prescaler
- Mode 1 16-bit time-interval or event counter
- Mode 2 8-bit time-interval or event counter with automatic reload upon overflow
- Mode 3 Timer 0 establishes TL0 and TH0 as two separate counters.

In the timer mode the register is incremented every machine cycle. Since a machine cycle consists of a minimum of 6 oscillator periods, the maximum count rate is  $\frac{1}{6} \times f_{\text{osc}}$ .

In the counter mode, the register is incremented in response to a HIGH-to-LOW transition. Since it takes one machine cycle (minimum 6 oscillator periods) to recognize a HIGH-to-LOW transition, the maximum count rate is  $\% \times \text{f}_{\text{osc}}$ . To ensure a given level is sampled, it should be held for at least one complete machine cycle.

## 4.8.1 TIMER T2

Note that the function of Timer 2 may deviate from the following description for certain products in the TELX family. In such a case, the deviation is described in the specific product data sheet.

Timer 2 is a 16-bit timer/counter that can operate as a timer, as an event counter or as a pulse width modulator. The following operating modes are available: External interrupt, T2-only, Auto-Reload and Capture mode. If Timer 2 is in the OFF state, its clock is switched off and the timer has an extremely low power consumption. Parallel to these operating modes, a Compare function and/or a pulse generator function is provided.

The operating modes are selected via the T2CON bits TR2, CP/RL2 and EXEN2 (see Table 13).





In the T2-only mode, TH2 and TL2 function as a 16-bit timer or counter which upon overflowing sets the Timer 2 overflow bit TF2. This may then be used to generate an interrupt.

In the Capture mode, TH2 and TL2 function as a 16-bit timer or counter which upon overflowing sets the Timer 2 overflow bit TF2. This may then be used to generate an interrupt. Additionally a HIGH-to-LOW transition at external input T2EX causes the current value in TL2 and TH2 to be captured into registers RCAP2L and RCAP2H respectively. In addition, the transition at T2EX causes the EXF2 interrupt flag in T2CON to be set, this may also be used to generate an interrupt. The Capture mode and the T2-only mode are shown in Fig.6.

In the Auto-Reload mode the 16-bit counter (TH2, TL2) does not continue counting at the value 0000H, after an overflow occurred, but will be reloaded with the 16-bit value stored in the SFRs RCAP2H and RCAP2L. If in Auto-Reload mode, the EXEN2 bit is set, a HIGH-to-LOW transition at external input T2EX will set the EXF2 bit and will also trigger the reloading of TH2,TL2. The Auto-Reload mode is shown in Fig.7.





Parallel to the T2-only, Capture and Auto-Reload mode, a compare function can be activated by writing a value other than 0000H to the compare SFRs COMP2H and COMP2L. A compare match is generated when the timer register TL2/TH2 increments to the value of the compare register COMP2L/COM2H. A compare match will set the compare flag CF2, this may also be used to generate an interrupt.

Parallel to the T2-only, Capture and Auto-Reload mode, a Pulse Width Modulation function can be activated by setting the ECOMP bit in the T2CON register. This will activate the alternative port function T2COMP for port bit P1.2. Every time a compare match or a timer overflow occurs, P1.2 (T2COMP) is toggled. The initial state of P1.2 after setting ECOMP is LOW.

If this pulse function is used in conjunction with the Auto-Reload mode and the compare function, a Pulse Width Modulation (PWM) function is realized. The PWM frequency is given by the reload value stored in register RCAP2L/RCAP2H. The PWM duty cycle is given by the value stored in register COMP2L/COMP2H. In Fig.8 an example of this is given with a 25/75% duty cycle.

As a special case, if both registers COMP2H and COMP2L are reset, the frequency on pin P1.2/T2COMP will be given only by the value of the reload register RCAP2L/RCAP2H and is half the frequency for an active compare. The duty cycle will be 50% as shown in Fig.9.





## 4.8.2 TIMER/COUNTER 2 CONTROL REGISTER (T2CON)

## **Table 14** Timer/Counter 2 Control Register (SFR address C8H)



## **Table 15** Description of T2CON bits



## 4.8.3 WATCHDOG TIMER

In addition to the standard timers and Timer 2, a Watchdog Timer consisting of an 13-bit prescaler and an 8-bit timer WDTIM is also incorporated. The prescaler is incremented by the external clock. The 8-bit timer is incremented every 8192 clock cycles.

If the clock frequency is 3.58 MHz, the Watchdog Timer can operate in the range of 2.3 ms up to 0.56 s. The Watchdog Timer is disabled after reset. It can be enabled by writing any value to the WDCON register. A running Watchdog Timer will only be disabled if the microcontroller enters Power-down mode or if the microcontroller is reset.

When a timer overflow occurs and the Watchdog Enable pin  $(\overline{EW})$  is LOW, the reset pin  $(\overline{RST})$  will be activated (pulled-down) and the microcontroller will be reset. To prevent an overflow of the Watchdog Timer, the user program must reload the Watchdog register within a period shorter than the programmed timer interval.



## 4.8.4 WATCHDOG TIMER INTERVAL REGISTER (WDTIM)

The reset value of WDTIM is 00H. The WDTIM register can only be written to if the WDCON register contains the value 5AH. The Watchdog Timer period can be calculated as follows:

Watchdog period =  $\frac{(256 - WDTIM) \times 8192}{4}$ f osc  $\frac{200 - \mathsf{W} \mathsf{D} \mathsf{H} \mathsf{M}}{4}$ 

**Table 16** Watchdog Timer Interval Register (SFR address FFH)



## **Table 17** Description of WDTIM bits



## 4.8.5 WATCHDOG TIMER CONTROL REGISTER (WDCON)

The Watchdog Timer is controlled by the WDCON register. A value of A5H in WDCON clears both the prescaler and the timer WDTIM. After reset WDCON contains the value A5H. Every value other than A5H in WDCON enables the Watchdog Timer. Since the WD0 bit of the WDCON input is tied to a logic 0 by hardware during write operations to WDCON, the reset value A5H can not be programmed again and can only be restored by a reset.

Timer WDTIM can be written only if WDCON has previously been loaded with 5AH, otherwise WDTIM and the prescaler are not affected. A successful write operation to WDTIM also clears the prescaler and clears WDCON.

Only the values A5H and 5AH are stored, all other values are stored with a dummy value 00H.

## **Table 18** Watchdog Control Register (SFR address A5H)



## **Table 19** Description of WDCON bits



## 4.8.6 PULSE WIDTH MODULATED OUTPUT

One pulse width modulated output channel is provided which outputs pulses of programmable length and interval. The repetition frequency is defined by an 8-bit prescaler (PWMP) that generates the clock for the counter. The 8-bit counter counts modulo 255 i.e. from 0 to 254 inclusive. The value held in the 8-bit counter is compared to the contents of the register PWM0. Provided the contents of this register are greater than the counter value, the PWM0 output is set LOW. If the contents of register PWM0 are equal to, or less than the counter value, the PWM0 output is set HIGH. The pulse-width-ratio is therefore defined by the contents of register PWM0. The pulse-width-ratio will be in the range 0 to 255/255 and may be programmed in increments of  $\frac{1}{255}$ .

The repetition frequency at the PWM0 output is given by:

$$
f_{\text{PWM}} = \frac{f_{\text{osc}}}{[(1 + \text{PWMP}) \times 255]}
$$

When using an oscillator frequency of 3.58 MHz for example, the above formula gives a repetition frequency range of 55 Hz to 14 kHz.

By loading the PWMO register with either 00H or FFH, the PWM0 output can be maintained at a constant HIGH or LOW level respectively. When loading FFH into the PWM0 register, the 8-bit counter will never actually reach this value.

The PWM0 output pin is driven by push-pull drivers and is not shared with any other function.



## 4.8.7 PRESCALER FREQUENCY CONTROL REGISTER (PWMP)

## **Table 20** Prescaler Frequency Control Register (SFR address FEH)



## **Table 21** Description of PWMP bits



## 4.8.8 PULSE WIDTH MODULATED REGISTER (PWM0)

## **Table 22** Pulse Width Modulated Register (SFR address FCH)



## **Table 23** Description of PWM0 bits



## <span id="page-27-0"></span>**4.9 EEPROM**

## 4.9.1 GENERAL DESCRIPTION

Most microcontrollers in the TELX family contain an on-chip low-power Electrically Erasable Programmable ROM (EEPROM) memory for non-volatile data storage. The memory offers the following features:

- Low power consumption
- No current consumption if the EEPROM is disabled (see Section 4.9.6)
- Single supply programming; the programming voltage is generated internally via an on-chip voltage multiplier
- Automatic ERASE before WRITE when programming
- User defined programming time (see Section 4.9.6)
- Page programming; 1 to 8 bytes can be programmed simultaneously, reducing programming time
- Accessible via I<sup>2</sup>C-bus:
- Fixed slave address
- Operates in Slave Transmitter or Slave Receiver modes
- Can be accessed from a master connected to the external I<sup>2</sup>C-bus (EEPROM access in external mode)
- Can be accessed from the host master even if ports P1.6 and P1.7 are not used as I<sup>2</sup>C-bus pins (EEPROM access in internal mode)
- Supports continuous read and page-write, (word address automatically incremented).

## 4.9.2 I2C-BUS OPERATION

The operation of the EEPROM memory depends on the state of the I<sup>2</sup>C-bus interface (see Section 4.12) and of the port pins P1.6 and P1.7 (see Section 4.7.2). Three situations are possible:

1. **EEPROM access in internal mode.** The I<sup>2</sup>C-bus serial I/O interface and the EEPROM memory are active, but the port pins P1.6 and P1.7 are not used as I 2C-bus pins.

The CPU of the TELX microcontroller can program and read the EEPROM. Port pins P1.6 and P1.7 can be used as open-drain ports for other purposes.

2. **EEPROM access in external mode.** The I<sup>2</sup>C-bus serial I/O master is not active, port pins P1.6 and P1.7 are configured as I<sup>2</sup>C-bus pins, and the EEPROM is active.

The EEPROM can be accessed from a master connected to the  $1<sup>2</sup>C$ -bus (see Fig.13), but not from the TELX CPU.

3. **EEPROM access in mixed mode**. Both the serial I/O interface and EEPROM are active, P1.6 and P1.7 are configured as I2C-bus pins.

Both the CPU of the TELX and external master(s) can read/programme the EEPROM.

After reset, the I<sup>2</sup>C-bus is in internal mode. In external mode, I<sup>2</sup>C-bus pull-up resistors must be connected to P1.6 and P1.7.



## **Table 24** EEPROM modes of operation

### **Notes**

- 1. See Section 4.7.2, Table 11.
- 2. See Section 4.12.
- 3. See Section 4.9.6.
- 4. When disabled, the EEPROM will not acknowledge any I<sup>2</sup>C-bus request, and consumes no power.





## 4.9.3 EEPROM ADDRESSING AND OPERATION

The EEPROM is accessed with an I2C Start (S) condition, followed by a 7-bit slave address and a control bit (R/W). Upon successful decoding of the address, the EEPROM answers with an I<sup>2</sup>C Acknowledge (A). Figure 14 shows the slave addresses for the different EEPROM sizes.

In microcontrollers with a 512-byte EEPROM, the 7<sup>th</sup> bit (A8) sent after the 6-bit slave address is part of the word address (A8 is the most significant address bit of the 512-byte EEPROM array).

The last bit of the slave address  $(R/\overline{W})$  defines the operation to be performed. When set to logic 1 a read operation is selected (the EEPROM will output the addressed data onto SDA at every SCL pulse), and when set to logic 0 the EEPROM will be ready to accept 7 bits of EEPROM address, possibly followed by data bytes to be stored in the EEPROM.

The master can abort any Read or Write operation at any time during I<sup>2</sup>C-bus data transfer by generating a new Start (S) without generating a Stop (P) condition.

## 4.9.4 WRITE OPERATIONS

## 4.9.4.1 Byte Write

After addressing the EEPROM with the R/W bit set to a logic 0, the EEPROM responds with an acknowledge and expects to receive a word address, followed by a byte of data to be written. In the case of a 512-byte EEPROM, the bit before R/W is the MSB of the word address of the byte to be written (A8). The master then sends the word address (A0 to A7), to which the EEPROM sends an acknowledge (A). Finally the master sends the data to be written, acknowledged by the EEPROM. The master sends a Stop condition (P) to start an Erase/Write cycle. The cycle takes typically 10 ms and is controlled by the E/W control circuitry (see Fig.12). The byte write sequence is shown in Fig.15, for the case  $n = 1$ .

Note that a Write to the EEPROM is implemented as a logical OR with the previously stored data; a Write operation must therefore be preceded with an Erase to clear the byte first. The E/W control logic will automatically generate the necessary Erase followed by the Write when a Stop condition is generated. The write time is specified for the complete Erase/Write cycle.

During the Erase/Write cycle the I2C-bus interface of the EEPROM is idle, i.e., it does not acknowledge when addressed (see also Section 4.9.4.3).

## 4.9.4.2 Page Write

In order to reduce total programming time when several bytes of data are to be written to the EEPROM, a page-write operation is available. Up to 8 bytes of data can be programmed with a single Erase/Write cycle, as long as all bytes are on the same page, i.e., their addresses only differ on the 3 lowest bits (A0 to A2). The sequence is similar to the byte-write: the master sends a Start (S) and slave address with the R/ $\overline{W}$  bit set to logic 0, followed by the word address of the first data byte to be programmed.

Then the first data byte is sent, and instead of immediately generating a Stop condition, the master sends up to 7 additional bytes; the 3 lowest bits of the address are automatically incremented, the highest bits remain fixed. The EEPROM acknowledges each data byte. Finally a Stop (P) is generated to start an Erase/Write cycle. This sequence is shown Fig.15.

Any number of bytes from 1 to 8 can be written, but their low addresses (A0 to A2) must be sequential. When the page addresses reaches end-of-page (A0 to A2 = 111), the address will wrap around to '000' (binary). Fig.16 shows two examples of possible page set-up; the first example shows eight bytes written starting from the beginning of the page (address 00H), and the second example shows six bytes written starting in the middle of the page, at address 15H.

If more then 8 bytes are sent by the master, the EEPROM will ignore and will **not** acknowledge the 9<sup>th</sup>, 10<sup>th</sup> etc., bytes. The master can proceed in one of two ways:

- Abort the write procedure, by sending a Start (S) and repeating the complete page-write procedure of Fig.15
- Start and Erase/Write cycle by generating a Stop (P). The first 8 bytes transmitted will be written into the EEPROM cells.

## 4.9.4.3 Acknowledge Polling

During programming, the EEPROM does not acknowledge when addressed by an I<sup>2</sup>C-bus master. To find out when the EEPROM is again accessible, the microcontroller must perform ACK polling, i.e. repeatedly send a Start and slave address and check if an acknowledge is generated.







## 4.9.5 READ OPERATIONS

An unlimited number of data bytes can be read, the address being automatically incremented after each byte is transmitted. A Read can be done in two ways: by first setting the word address (Random Read), or without setting the word address (Current Address Read). Both ways allow to sequentially read any number of bytes (Sequential Read).

## 4.9.5.1 Current Address Read

The master addresses the EEPROM slave with the R/ $\overline{W}$  bit set to a logic 1. The EEPROM acknowledges, transmits the data byte addressed by the current contents of the address pointer, and increments it by 1. The master ends the read operation by generating a No-acknowledge  $(A = 1)$  and Stop  $(P)$ .

If the master wishes to read more than one byte (Sequential Read), it generates an Acknowledge  $(A = 0)$ after receiving the data byte, and does not generate a Stop. Any number of bytes can be read with this procedure; the address pointer will wrap-around to address 00H when the highest address is read. To end Sequential Read, the master generates a No-acknowledge  $(A = 1)$  and a Stop  $(P)$ . Figure 17 illustrates the Current Address Read and Sequential Read procedure.

When using the Current Address Read, the contents of the address pointer are equal to the address of the byte previously accessed (either by a previous read or write) incremented by 1; e.g., if the previous action was writing or reading byte addressed by 'n', using Current Address Read will retrieve the byte addressed by 'n  $+1$ '.

**Note** there is an exception to the above rule: when using Current Address Read with 512-byte EEPROMs, the MSB of the current read address (A8) is overwritten each time the Slave address is sent. For example, if the byte previously accessed was addressed by 000H, and the EEPROM is selected using  $AB = 1$ , the data retrieved will be in address 101H ( $A8 = 1$ ,  $A0$  to  $A7$  incremented by 1) and not 001H.

## 4.9.5.2 Random Read

In Random Read mode, the address of the byte to be read is sent prior to the read. The master selects the EEPROM with the R/W bit set to logic 0 (write), and upon Acknowledge from the EEPROM sends the 8-bit word address, which is loaded into the Address pointer and acknowledged by the EEPROM. The master then sends a Repetitive Start (Sr, a Start without previously having generated a Stop) selecting again the slave with the  $R/\overline{W}$ bit to logic 1 (read). The EEPROM transmits the byte addressed by the address pointer and increments it at the end. The master ends Random Read by generating a No-acknowledge  $(A = 1)$  and a Stop  $(S)$ .

If the master wishes to read more bytes, it generates an Acknowledge  $(A = 0)$  after receiving each byte (Sequential Read). Any number of bytes can be read; the address pointer will wrap-around to address 00H when the highest address is read. To end Sequential Read, the master generates a No-acknowledge  $(A = 1)$  and a Stop  $(P)$ . Figure 18 shows the Random Read and Sequential Read procedure.

**Note** when using Random Read with EEPROM memories with 512-bytes, the MSB of the word address (A8) sent during the Write frame is overwritten when the slave is addressed a second time, after the Repetitive Start (Sr). For example, if the word-address sent is 000H  $(AB = 0)$ , and the slave address after the Repetitive Start contains  $A8 = 1$ , then the data retrieved is addressed by 100H and not 000H.





## 4.9.6 EEPROM CONTROL REGISTER (EECON)

This Special Function Register controls the operation of the EEPROM. The programming time (Erase/Write cycle) is defined by the crystal frequency, the pre-scaler division factor and the EECON bits (EEC0 to EEC6). Erase and Write operations take the same time. Typically 4 to 5 ms are necessary to erase or write the EEPROM cells giving a total Erase/Write cycle time of 8 (minimum) to 10 ms.

To achieve these programming times, the E/W control circuit requires a clock (EEPROM clock, see Fig.12) with a frequency between 51 and 63.75 kHz (max.). Frequencies lower than 51 kHz are acceptable, but result in a programming time greater than 10 ms. The frequency of XTAL is divided by the contents of the PSC register to define the internal clock frequency. This clock is then divided by the contents of the EEC0 to EEC6 bits to generate the 51 kHz EEPROM clock. The Erase and Write times are obtained by further dividing this clock by 255.

The total Erase/Write time is given by the relationship shown below:

$$
t_{WR} = 2 \times 255 \times \frac{XTAL1}{PSC \times EECON}
$$

To determine the EECON value given the XTAL frequency and the PSC factor the relationship shown below should be used:

$$
EECON = \frac{XTAL1 \times t_{WR}}{PSC \times 510}
$$

Note that EECON can only take integer values between 2 and 127. Table 27 shows some examples of XTAL frequencies, Prescaler Division Factor and EECON values and the resulting Erase/Write times.

## **Table 25** EEPROM Control Register (see Section 4.6 for the SFR addressing)



## **Table 26** Description of EECON bits



## **Table 27** EEPROM division factor examples



### **Note**

1. The EECON division value is in decimal notation and between brackets in binary. The EEPE bit is set to a logic 1 in all cases. The smallest EECON VALUE is 2 (1000 0010). EECON VALUE = 1 (1000 0001) or 0 (1000 0000) generates no EEPROM clock and should not be used.

## <span id="page-34-0"></span>**4.10 DTMF generator section**

A versatile frequency generator section is provided and is shown in Fig.19. For normal operation use a 3.579545 MHz (or a multiple of this frequency) quartz crystal or PXE resonator. The frequency generator includes precision circuitry for dual-tone multi-frequency (DTMF) signals, which is typically used for tone dialling telephone sets. The TONE output can alternatively issue twelve modem frequencies for data rates between 300 and 1200 bits/s. In addition to DTMF and modem frequencies, two octaves of musical scale in steps of semitones are available.

## 4.10.1 FREQUENCY REGISTERS

The two frequency registers (LGF and HGF) define two frequencies and from these, the digital sine wave synthesizers together with the Digital-to-Analog Convertors construct two sine waves. Their amplitudes are precisely scaled according to the bandgap voltage reference. This ensures tone output levels independent of supply voltage and temperature.

The amplitude of the Low Group Frequency sine wave is attenuated by 2 dB compared to the amplitude of the High Group Frequency sine wave.

The two sine waves are summed and then filtered by on-chip switched capacitor and RC low-pass filters. These guarantee all DTMF tones generated fulfil the CEPT CS203 recommendations with respect to amplitude, frequency deviation, total harmonic distortion and suppression of unwanted frequency components. A value of 00H in a frequency register stops the corresponding digital sine wave synthesizer. If both frequency registers contain 00H, the whole frequency generator is shut off, resulting in lower power consumption. A decimal value of 'x' in a frequency register yields a digital sine wave signal with frequency:

$$
f = \frac{f_{xtal}}{[23 (x + 2)]}
$$
; where 60  $\le x \le 255$ 

The frequency limitation given by  $x \ge 60$  is due to the low-pass filters which would attenuate higher frequency sine waves.



## 4.10.2 LOW GROUP FREQUENCY REGISTER (LGF)

## **Table 28** Low Group Frequency Register (address A1H; access type W)



**Table 29** Description of LGF bits



### 4.10.3 HIGH GROUP FREQUENCY REGISTER (HGF)

**Table 30** High Group Frequency Register (address A2H; access type W)



### **Table 31** Description of HGF bits



4.10.4 ALTERNATIVE PORT FUNCTION CONTROL REGISTER (ALTP)

**Table 32** Alternative Port Control Register (address A3H; access type W)



## **Table 33** Description of ALTP bits


## 4.10.5 DTMF FREQUENCIES

The input frequency to the frequency generator is  $f_{PSC}$ . Assuming an oscillator frequency of a multiple of  $f_{\text{DTMF}} = 3.579545$  MHz, the division factor of the prescaler should be chosen such that  $f_{\text{PSC}} = f_{\text{DTMF}}$ . The DTMF standard frequencies can then be implemented as shown in Table 34. The relationship between telephone keyboard symbols and the frequency register contents are given in Table 35.



#### **Table 34** DTMF standard frequencies and their implementation





### 4.10.6 MODEM FREQUENCIES

Assuming an oscillator frequency of  $f_{PSC} = f_{DTMF} = 3.579545$  MHz, the standard modem frequency pairs summarized in Table 36 can be implemented. It is suggested to define the frequency using the HGF register while the LGF register contains 00H, disabling Low Group Frequency generation.



**Table 36** Standard modem frequency pairs and their implementation

#### **Notes**

- 1. Standard is V.21.
- 2. Standard is Bell 103.
- 3. Standard is Bell 202.
- 4. Standard is V.23.

## 4.10.7 MUSICAL SCALE FREQUENCIES

Finally, two octaves of musical scale in steps of semitones can be realized, again assuming an oscillator frequency  $f_{PSC} = f_{DTMF} = 3.579545$  MHz (Table 37). It is suggested to define the frequency using the HGF register while the LGF register contains 00H, disabling Low group frequency generation.



**Table 37** Musical scale frequencies and their implementation

#### **Note**

1. Standard scale based on A4 at 440 Hz.

# Low voltage 8-bit microcontrollers example of the TELX family

## **4.11 MSK modem**

The MSK modem is used for in-band signalling between handset and base in analog cordless telephone systems CT0, CT1 and CT1+. The MSK modem's receiver and transmitter can be enabled separately. Receive and transmit interrupts can wake-up the microcontroller during its power saving Idle mode. Baud rates are programmable between 1200 and 4800 Baud. Fig.20 shows the functional diagram of the MSK modem.

The modem has the following features:

- Full duplex operation via 8-bit parallel interface
- The message is fully Manchester coded/decoded
- Automatic detection of 16-bit Manchester preamble pattern
- The last received 4 bits of the preamble pattern are software programmable
- Receiver full, transmitter empty indication bits
- Manchester coding and decoding for clock recovery and early error detection
- Programmable input polarity
- Baud rate selection from 1200, 2400, 3600 and 4800 baud with internal modem timer
- Receiver and transmitter off-states with no power consumption.



## 4.11.1 80C51 MICROCONTROLLER INTERFACE

The modem block interfaces to the microcontroller via the interrupt signals MRI and MTI and via the control and data SFRs MCON, MSTAT and MBUF. The MSK modem receive and transmit registers are both accessed via the Special Function Register MBUF. Writing to MBUF loads the transmit register and reading MBUF accesses a physically separate receive register.

#### 4.11.1.1 MSK Modem Control Register (MCON)

#### **Table 38** MSK Modem Control Register (SFR address D3H)



#### **Table 39** Description of MCON bits



#### **Note**

1. If both the transmitter and the receiver are disabled (MTEN = 0 and MREN = 0), the clock of the MSK modem is switched-off. It is advised to use this state for power saving.

#### **Table 40** Selection of the modem's baud rates



## 4.11.1.2 MSK Modem Status Register (MSTAT)

## **Table 41** MSK modem Status Register (SFR address D2H)



#### **Table 42** Description of MSTAT bits



## 4.11.1.3 MSK Modem Data Buffer (MBUF)





## **Table 44** Description of MBUF bits



## 4.11.2 MODEM INTERFACE

The modem block has the following modem interface signals.

- **MIN:** digital MSK Manchester coded input signal from the Data slicer. MIN is the alternative input function of P4.0. If P4.0 is used for MIN, it has to be configured to be an input port. The data that is written to the ports data SFR can be used to switch the polarity of MIN. If P4.0 data is set, the value on the pin is passed to MIN with inverted polarity. If P4.0 data is reset, the value on the pin is passed directly to MIN.
- **MOUT0 to MOUT2:** 3-bit Manchester coded output signal of the modem.

The mute signals RX\_MUTE and TX\_MUTE must be generated by software. Any standard I/O port pin can be used for this purpose.

## 4.11.3 DATA TRANSMISSION

Data transmission is enabled if bit MTEN in register MCON is set to a logic 1. If MTEN is a logic 0, data transmission is disabled and MOUT<2:0> is set to <111> to zero the currents in the resistive DAC. Setting MTEN to a logic 1 sets MOUT<2:0> to the idle value <100>. This results in a value close to  $\frac{1}{2} \times$  V<sub>DD</sub> on the output signal of the external DAC. Transmission is started by loading the first byte into register MBUF. All bytes are transmitted starting with the MSB.

A message is transferred in a block of 3 or more bytes, the first two bytes being the programmed Manchester preamble pattern. In order to insert the preamble pattern, the first two bytes AAH and AXH (with X being the MPR3 to MPR0 value programmed in the receiver MSK modem) have to be written to MBUF by software. After this, the first byte of the message is written to MBUF. As soon as MBUF is ready to accept new input, signal MTI is set. A new byte written to MBUF automatically clears MTI. The time between two MTI interrupts is  $T = 8 \times 1$  baud rate (e.g. for baud rate 1200 baud,  $T = 6.7$  ms). If no new byte is written to MBUF at the end of a byte transmission, the modem transmitter stops transmission and MOUT<2:0> is set to the idle state <100>.

In this case MTI must be cleared explicitly. If MTEN is reset during transmission, the transmitter will finish the transmission of the current byte and then will set MOUT<2:0> to the off state <111>. No interrupt on MTI will be generated at the end of the transmission.

## 4.11.4 DATA RECEPTION

A message is received as a block of one or more data bytes. When enabled, the receiver starts sampling MIN and tries to detect a Manchester pattern. As soon as 3 consecutive Manchester bits are detected the receiver clock is locked (MRL = 1) and the receiver starts scanning the incoming data for the programmed Manchester preamble pattern. When the modem recognizes the preamble pattern, bit MRP is set to a logic 1. If a non-Manchester bit is detected before finding the preamble pattern then MRL is reset and MRE is set to a logic 1. The synchronisation process has to restart. If the preamble pattern has been detected the receiver starts to Manchester decode the incoming data bits and shifts them into an internal register. After eight bits the contents of the internal register are copied to MBUF and MRF bit is set to a logic 1. The received byte can be read from MBUF while receiving continues in the internal register. If a non-Manchester bit is received during data reception then MRE is set to a logic 1 and MRL and MRP are reset. The receiver has to resynchronize before receiving new data.

Whenever one of the bits MRF, MRE, MRP and MRL is set the MRI bit is also set and an RTI interrupt is generated. This means that when an RTI interrupt occurs the 4 status bits have to be polled by software. The bit MRL allows the software to decide very quickly whether an occupied channel contains Manchester coded data or not. The MRP bit is used to find the start of data transmission in a message that is repeated over and over again. MRE is used to detect a Manchester error, which is a violation of the Manchester coding rule that the received level should change in the middle of a bitcell. The MRF bit indicates that the data in MBUF is ready to be read by the software. During data reception the time between two settings of MRF (each one generating an MRI interrupt) is  $T = 8 \times 1$ /baud rate. Figure 22 shows an example of the timing diagram of data reception.

## 4.11.5 MANCHESTER CODING OF DATA

The bits of the data byte written in MBUF are Manchester encoded as shown in Fig.22: A '1' is coded as a LOW-to-HIGH transition in the middle of a bitcell, a '0' is coded as a HIGH-to-LOW transition.The Manchester encoded signal contains redundancy for early error detection in received bits. A non-matching HIGH-to-LOW or LOW-to-HIGH pair indicates an error condition.The Manchester encoded signal has a polarity change in each bitcell.





#### 4.11.6 WAVEFORM GENERATION WITH MOUT<2:0>

The 3 digital output pins MOUT0 to MOUT2, should be used as an input to a three bit external DAC. The signals can be connected via external resistors R0, R1 and R2 to a summation point and then be filtered with an external capacitor (C1). The 3-bit DAC is shown in Fig.23. Table 45 gives the relationship between the MOUT pins, the resistor values and VOUT.

Figure 24 shows the waveforms that are produced by the waveform generator. The horizontal axis shows the sample counter on which the waveform changes its value. Each bit is built-up out of  $2 \times 124$  samples. The vertical axis shows the values of MOUT<2:0>, forming the inputs of the resistive DAC. The first half of the waveform is determined by the previous and the current bit, whereas the second half of the waveform is determined by the current and the next bit to be transmitted. The count frequency of the sample counter depends on the programmed baud rate.

If the transmitter is disabled with MTEN set to a logic 0, MOUT<2:0> is <111> to save power in the resistive DAC. If the transmitter is enabled and no data is transmitted, MOUT<2:0> has an idle value of <100>, which corresponds to  $0.57 \times V_{DD}$ .

#### 4.11.7 SYNCHRONISATION

When enabled the receiver samples MIN with a frequency  $f=8 \times$  baud rate. The sampled values are shifted into an 8-bit shift register. This register is regularly checked to determine whether it contains samples that fulfil the Manchester coding rule i.e. whether there is a LOW-to-HIGH or a HIGH-to-LOW transition in the middle of the bitcell. The receiver searches for 3 consecutive sets of 8 samples that fulfil the Manchester coding rule. If these sets have been found the clock is locked ( $MRL = 1$ ) and the receiver starts looking for the Manchester preamble pattern. From this point on the receiver uses a PLL (Phase Locked Loop) to adjust the synchronisation after each received Manchester bit.









## **4.12 I2C-bus serial I/O**

The serial port supports the twin line I<sup>2</sup>C-bus. The I<sup>2</sup>C-bus consists of two lines: a data line (SDA) and a clock line (SCL). These lines also function as the I/O port lines P1.7 and P1.6 respectively. The system is unique because data transport, clock generation, address recognition and bus control arbitration are all controlled by hardware.

The I<sup>2</sup>C-bus serial I/O has complete autonomy in byte handling and operates in 4 modes:

- Master transmitter
- Master receiver
- Slave transmitter
- Slave receiver.

These functions are controlled by the S1CON register. S1STA is the Status Register whose contents may also be used as a vector to various service routines. S1DAT is the Data Shift Register and S1ADR the Slave Address Register. Slave address recognition is performed by on-chip hardware. The block diagram of the I<sup>2</sup>C-bus serial I/O is shown in Fig.25.

#### 4.12.1 **I 2C-bus internal mode**

A special internal mode is provided. In this mode other on-chip blocks with an I2C-bus interface can communicate without using the I/O port lines P1.7 and P1.6, thus freeing them for other purposes. The microcontroller can be configured to use this internal mode or the normal external mode, with the port configuration bits; see Section 4.7.2.



## 4.12.2 SERIAL CONTROL REGISTER (S1CON)

## **Table 46** Serial Control Register (SFR address D8H)



## **Table 47** Description of S1CON bits





**Table 48** Selection of the serial clock frequency in the Master mode of operation; see notes 1 and 2

#### **Notes**

1. Bit rates greater than 400 kHz are outside the specified frequency range.

2. When the CR (2:0) = 111, the maximum bit rate for the data transfer will be derived from the Timer 1 overflow rate divided by 2, i.e. every time the Timer 1 overflows the SCL signal will toggle.

## 4.12.3 DATA SHIFT REGISTER (S1DAT)

S1DAT contains the serial data to be transmitted or data which has just been received. Bit 7 is transmitted or received first; i.e. data shifted from left to right.

#### **Table 49** Data Shift Register (SFR address DAH)



## 4.12.4 ADDRESS REGISTER (S1ADR)

This 8-bit register may be loaded with the 7-bit slave address to which the controller will respond when programmed as a slave receiver/transmitter.

#### **Table 50** Address Register (SFR address DBH)



#### **Table 51** Description of S1ADR bits



## 4.12.5 SERIAL STATUS REGISTER (S1STA)

The contents of this register may be used as a vector to a service routine. This optimizes the response time of the software and consequently that of the I<sup>2</sup>C-bus. S1STA is a read-only register. The status codes for all possible modes of the I2C-bus interface are given in Tables 54 to 58.

#### **Table 52** Serial Status Register (SFR address D9H)



#### **Table 53** Description of S1STA bits



#### **Table 54** MST/TRX mode



#### **Table 55** MST/REC mode



## Philips Semiconductors **Philips Semiconductors Preliminary specification**

## **Table 56** SLV/REC mode



#### **Table 57** SLV/TRX mode



## **Table 58** Miscellaneous



## **Table 59** Symbols used in Tables 54 to 58



## **4.13 Standard serial interface SIO0: UART**

This serial port is full duplex which means that it can transmit and receive simultaneously. It is also receive-buffered and can commence reception of a second byte before a previously received byte has been read from the register. (However, if the first byte has not been read by the time the reception of the second byte is complete, the second bytes will be lost). The serial port receive and transmit registers are both accessed via the Special Function Register S0BUF. Writing to S0BUF loads the transmit register and reading S0BUF accesses a physically separate receive register.

The serial port can operate in 4 modes:

- Mode 0 Serial data enters and exits through RXD. TXD outputs the shift clock. 8 bits are transmitted/received (LSB first). The baud rate is fixed at  $\frac{1}{6}$  the oscillator frequency.
- Mode 1 10 bits are transmitted (through TXD) or received (through RXD): a start bit (0), 8 data bits (LSB first) and a stop bit (1). On receive, the stop bit goes into RB8 in Special Function Register S0CON. The baud rate is variable.
- Mode 2 11 bits are transmitted (through TXD) or received (through RXD): a start bit (0), 8 data bits (LSB first), a programmable 9<sup>th</sup> data bit and a stop bit (1). On transmit, the 9th data bit (TB8 in S0CON) can be assigned the value of 0 or 1. Or, for example, the parity bit (P, in the PSW) could be moved into TB8. On receive, the  $9<sup>th</sup>$  data bit goes into RB8 in S0CON, while the stop bit is ignored. The baud rate is programmable to either  $\frac{1}{32}$  or  $\frac{1}{64}$  of the oscillator frequency.
- Mode 3 11 bits are transmitted (through TXD) or received (through RXD): a start bit (0), 8 data bits (LSB first), a programmable  $9<sup>th</sup>$  data bit and a stop bit (1). In fact, Mode 3 is the same as Mode 2 in all respects except baud rate. The baud rate in Mode 3 is variable.

In all four modes, transmission is initiated by any instruction that uses S0BUF as a destination register. Reception is initiated in Mode 0 by the condition  $RI = 0$  and  $REN = 1$ . Reception is initiated in the other modes by the incoming start bit if  $REN = 1$ .

## 4.13.1 MULTIPROCESSOR COMMUNICATIONS

Modes 2 and 3 have a special provision for multiprocessor communications. In these modes, 9 data bits are received. The 9<sup>th</sup> bit goes into RB8. The following bit is the stop bit. The port can be programmed such that when the stop bit is received, the serial port interrupt will be activated, but only if RB8 = 1. This feature is enabled by setting bit SM2 in S0CON. One use of this feature, in multiprocessor systems, is as follows.

When the master processor wants to transmit a block of data to one of several slaves, it first sends out an address byte which identifies the target slave. An address byte differs from a data byte in that the 9<sup>th</sup> bit is HIGH in an address byte and LOW in a data byte. With  $SM2 = 1$ , no slave will be interrupted by a data byte. An address byte, however, will interrupt all slaves, so that each slave can examine the received byte and see if it is being addressed. The addressed slave will clear its SM2 bit and prepare to receive the data bytes that will be sent. The slaves that were not being addressed leave their SM2 bits set and go on about their business, ignoring the coming data bytes.

SM2 has no effect in Mode 0, and in Mode 1 can be used to check the validity of the stop bit. In a Mode 1 reception, if SM2 = 1, the receive interrupt will not be activated unless a valid stop bit is received.

## 4.13.2 SERIAL PORT CONTROL REGISTER (S0CON)

The Serial Port Control and Status Register is the Special Function Register S0CON; shown in Table 60. The register contains not only the mode selection bits, but also the 9<sup>th</sup> data bit for transmit and receive (TB8 and RB8), and the serial port interrupt bits (TI and RI).

## **Table 60** Serial Port Control Register (SFR address 98H)



## **Table 61** Description of S0CON bits



## **Table 62** Selection of the serial port modes



#### 4.13.3 BAUD RATES

In Mode 0 the baud rate is fixed as shown in Eqtn.(1):

$$
Baud rate = \frac{f_{osc}}{6}
$$
 (1)

In Mode 2 the baud rate depends on the value of the SMOD bit in the PCON register and is calculated as shown in Eqtn.(2).

$$
Baud rate = \frac{2^{SMOD}}{64} \times f_{osc}
$$
 (2)

For Modes 1 and 3 baud rates see Section 4.13.3.1.

## 4.13.3.1 Using the special purpose baud rate Timer to generate baud rates

In Modes 1 and 3 the baud rate is determined by the overflow rate of the special purpose baud rate timer and the value of the SMOD bit, as shown in Eqtn. (3):

Baud rate = 
$$
\frac{2^{SMOD}}{32} \times \text{baud rate timer overflow rate} \qquad (3)
$$

The baud rate timer overflow rate is controlled by the value of the bits PRESC.7 to PRESC.3 in the PRESC register according to Eqtn.(4)

$$
Time overflow rate = f_{PSC} \times \frac{1}{2^{PTW0} \times 3^{P3}}
$$
 (4)

This gives the following formula for the baud rate:

$$
Baud rate = \frac{2^{SMOD}}{32} \times f_{PSC} \times \frac{1}{2^{PTWO} \times 3^{P3}}
$$
 (5)

PTWO (PRESC.6 to PRESC.4) defines a power of two in the division factor of the baud rate timer. P3 (PRESC.3) defines a factor of 3 or 1 in the division factor of the baud rate timer.  $f_{PSC}$  is the frequency defined by the prescaler (see Section 4.3) and is the DTMF frequency of 3.579545 MHz in typical telecom applications. The prescaler is controlled with the PS0 to PS2 bits in the PRESC register. Table 63 lists various commonly used baud rates and how they can be obtained with the special purpose baud rate timer and the PRESC register. For detailed description on PRESC see Section 4.3.1.



**Table 63** Baud rate timer generated commonly used baud rates, based on  $f_{PSC} = 3.579545$  MHz

#### **Notes**

- 1. Error compared to the target values is less then 3%.
- 2. Maximum baud rate.
- 3. And also 1100 and 1110.
- 4. Minimum baud rate.
- 5. And also 1101 and 1111.



Philips Semiconductors Philips Semiconductors Preliminary specification

Preliminary specification

# Low voltage 8-bit microcontrollers TELX family Low voltage 8-bit microcontrollers

TELX family







TELX family



88



Philips Semiconductors Philips Semiconductors Preliminary specification

Preliminary specification

Low voltage 8-bit microcontrollers TELX family Low voltage 8-bit microcontrollers

TELX family





Philips Semiconductors

Philips Semiconductors Preliminary specification Preliminary specification

TELX family



 $\mathcal{L}^{\mathcal{D}}$ 

## **4.14 Interrupt system**

External events and the real-time-driven on-chip peripherals require service by the CPU asynchronously to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution a multiple-source, two-priority-level, nested interrupt system is provided. The TELX family acknowledges interrupt requests from twenty sources:

- INT0 to INT9
- Timer 0, Timer 1 and Timer 2
- I 2C-bus serial I/O
- UART transmitter and receiver
- MSK modem transmitter and receiver
- Low Voltage Detector
- 32 kHz Real-Time Clock.

Each interrupt vectors to a separate location in program memory for its service routine. Each source can be individually enabled or disabled by its corresponding bit in the Interrupt Enable Registers (IEN0 to IEN2). The priority level is selected via the Interrupt Priority Registers (IP0 to IP2). All enabled sources can be globally disabled or enabled. The interrupt system is shown in Fig.34.

## 4.14.1 EXTERNAL INTERRUPTS INT2 TO INT9

Port 1 lines serve an alternative purpose as eight additional interrupts: INT2 to INT9. When enabled, each of these lines may wake-up the device from the Power-down mode.

Using the Interrupt Polarity Register (IX1) and the Interrupt Sensitivity Register (ISE1), each pin may be initialized to be either active HIGH, active LOW (i.e. level sensitive), or triggered on a rising or falling edge. A Port 1 level sensitive interrupt will be recognized when a level (HIGH or LOW depending on the Interrupt Polarity Register) on P1.n  $(n = 0$  to 7) is held active for at least one machine cycle. The interrupt request is not serviced until the next machine cycle. The external interrupt configuration is shown in Fig.35.

IRQ1 is the Interrupt Request Flag Register. If the interrupt is enabled, each flag will be set on an interrupt request but must be cleared by software, i.e. via the interrupt software or when the interrupt is disabled by its corresponding bit in IE1. A global interrupt disable will disable the servicing of the interrupts however it does not reset an active interrupt request neither does it stop the detection of an interrupt condition.

## 4.14.2 INTERRUPT PRIORITY

Each interrupt source can be set to either a high priority or to a low priority. If both priorities are requested simultaneously, the processor will branch to the high priority vector. A low priority interrupt can only be interrupted by a high priority interrupt. A high priority interrupt routine can not be interrupted.

Table 64 shows the interrupt vectors in order of priority. X0 having the highest priority; RTC the lowest. The vector indicates the ROM location where the appropriate interrupt service routine starts.

**Table 64** Interrupt vectors







## 4.14.3 INTERRUPT ENABLE REGISTER (IEN0)

#### **Table 65** Interrupt Enable Register (SFR address A8H)



#### **Table 66** Description of IEN0 bits



#### **Note**

1. Where: logic  $0 =$  interrupt disabled; logic  $1 =$  interrupt enabled.

## 4.14.4 INTERRUPT ENABLE REGISTER (IEN1)

#### **Table 67** Interrupt Enable Register (SFR address E8H)



#### **Table 68** Description of IEN1 bits



#### **Note**

1. Where: logic  $0 =$  interrupt disabled; logic  $1 =$  interrupt enabled.

## 4.14.5 INTERRUPT ENABLE REGISTER (IEN2)

#### **Table 69** Interrupt Enable Register (SFR address F1H)



#### **Table 70** Description of IEN2 bits



#### **Note**

1. Where: logic  $0 =$  interrupt disabled; logic  $1 =$  interrupt enabled.

4.14.6 INTERRUPT PRIORITY REGISTER (IP0)

#### **Table 71** Interrupt Priority Register (SFR address B8H)



## **Table 72** Description of IP0 bits



#### **Note**

1. Where: logic  $0 =$  low priority; logic  $1 =$  high priority.

## 4.14.7 INTERRUPT PRIORITY REGISTER (IP1)

#### **Table 73** Interrupt Priority Register (SFR address F8H)



#### **Table 74** Description of IP1 bits



#### **Note**

1. Where:  $logic 0 = low priority$ ; logic  $1 = high priority$ .

#### 4.14.8 INTERRUPT PRIORITY REGISTER (IP2)

#### **Table 75** Interrupt Priority Register (SFR address F9H)



#### **Table 76** Description of IP2 bits



#### **Note**

1. Where: logic  $0 =$  low priority; logic  $1 =$  high priority.

## 4.14.9 INTERRUPT POLARITY REGISTER (IX1)

Writing either a logic 1 or logic 0 to any Interrupt Polarity Register bit sets the polarity level of the corresponding external interrupt to an active HIGH (rising edge) or active LOW (falling edge) respectively.





#### **Table 78** Description of IX1 bits



#### 4.14.10 INTERRUPT SENSITIVITY REGISTER (ISE1)

Writing either a logic 1 or logic 0 to an Interrupt Sensitivity Register bit sets the type of the corresponding external interrupt to edge sensitive or level sensitive respectively.

#### **Table 79** Interrupt Sensitivity Register (SFR address E1H)



#### **Table 80** Description of ISE1 bits



## 4.14.11 INTERRUPT REQUEST FLAG REGISTER (IRQ1)

## **Table 81** Interrupt Request Flag Register (SFR address C0H)



#### **Table 82** Description of IRQ1 bits



#### 4.14.12 INTERRUPT RELATED REGISTERS

The following registers are used in conjunction with the interrupt system.

#### **Table 83** Interrupt Related registers



#### **4.15 Idle and Power-down operation**

Idle mode operation permits the interrupt, serial ports (UART and I2C-bus), serial interfaces, RTC and timer blocks to continue to function while the clock to the CPU is halted.

The following functions remain active during the Idle mode. These functions may generate an interrupt or reset; thus ending the Idle mode.

- Timer 0, Timer 1 and Timer 2
- UART and I<sup>2</sup>C-bus interface
- MSK modem
- External interrupts
- 32 kHz Real-Time Clock.

The Power-down operation stops the oscillator and reduces power consumption to a few micro-amps. This mode can only be activated by setting the PD bit in the PCON register or via the Low Voltage Detector. The Idle and Power-down clock configuration is shown in Fig.36.

#### 4.15.1 IDLE MODE

The instruction that sets PCON.0 is the last instruction executed in the normal operating mode before the Idle mode is activated. Once in the Idle mode, the CPU status is preserved along with the Stack Pointer, Program Counter, Program Status Word and Accumulator. The RAM and all other registers maintain their data during Idle mode.

There are two ways to terminate the Idle mode:

1. Activation of any enabled interrupt will cause PCON.0 to be cleared by hardware thus terminating the Idle mode. The interrupt is serviced, and following the RETI instruction, the next instruction to be executed will be the one following the instruction that put the device in the Idle mode. The flag bits GF0 and GF1 may be used to determine whether the interrupt was received during normal execution or during the Idle mode. For example, the instruction that writes to PCON.0 can also set or clear one or both flag bits. When the Idle mode is terminated by an interrupt, the service routine can examine the status of the flag bits. 2. The second way of terminating the Idle mode is with an external hardware reset, or an internal reset caused by an overflow of the Watchdog Timer. Since the oscillator is still running, the hardware reset is required to be active for two machine cycles (12 oscillator periods) to complete the reset operation. Reset redefines all SFRs but does not affect the on-chip RAM.

#### 4.15.2 POWER-DOWN MODE

The instruction that sets PCON.1 is the last executed prior to going into the Power-down mode. Once in the Power-down mode, the oscillator is stopped. The contents of the on-chip RAM and the SFRs are preserved. The port pins output the value held in their respective SFRs. ALE is held LOW and **PSEN** is held HIGH.

The EEPROM should be switched off via register EECON before the Power-down mode is entered. Make sure not to enter the Power-down mode before a write or erase cycle is finished. For details on EEPROM operations, see Section 4.9.

The Power-down mode can also be entered and exited automatically by using the on-chip Low Voltage Detection circuit. This is described in Sections 4.18.2 and 4.18.3.

To reach lowest possible power consumption it is strongly recommended to write 00H in both the DTMF frequency registers HGF and LGF.

In the Power-down mode,  $V_{DD}$  may be reduced to minimize circuit power consumption. The supply voltage must not be reduced until the Power-down mode is entered, and must be restored before the hardware reset is applied which will free the oscillator. Reset should not be released until the oscillator has restarted and stabilized.

#### 4.15.3 WAKE-UP FROM POWER-DOWN MODE

Setting the PD flag in the PCON register forces the controller into the Power-down mode. Setting this flag enables the controller to be woken-up from the Power-down mode with either the external interrupts INT2 to INT9, a reset operation, the LVD or via the RTC.

## 4.15.3.1 Wake-up using INT2 to INT9

If any of the interrupts INT2 to INT9 are enabled, the device can be woken-up from the Power-down mode with the external interrupts. To ensure that the oscillator is stable before the controller restarts, the internal clock will remain inactive for either 32 or 1024 oscillator periods. The length of the delay is programmable via the DELS bit in the PCON register. The delay is generated by an on-chip delay counter. After reset, 1024 oscillator periods delay is the default setting.

## 4.15.3.2 Wake-up using RST

If using the RST pin for Wake-up, refer to Section 4.17.1.

## 4.15.3.3 Wake-up using LVD

The Power-down mode can be entered and exited automatically by using the on-chip Low Voltage Detection circuit. This is described in detail in the Section 4.18.2.

**Table 84** Status of external pins during Idle and Power-down modes

## 4.15.3.4 Wake-up using RTC

The on-chip 32 kHz Real-Time Clock (RTC) can be used to wake-up the microcontroller periodically without reset. This is described in detail in Section 4.4.

#### 4.15.4 STATUS OF EXTERNAL PINS

The status of the external pins during Idle and Power-down mode is shown in Table 84. If the Power-down mode is activated whilst accessing external program memory, the port data that is held in the Special Function Register P2 is restored to Port 2. If the data is a logic 1, the port pin is held HIGH during the Power-down mode by the strong pull-up transistor p1 (see Fig.5).






## 4.15.5 POWER CONTROL REGISTER (PCON)

The reduced power modes are activated by software using this Special Function Register. PCON is not bit addressable.

# **Table 85** Power Control Register (SFR address 87H)



## **Table 86** Description of PCON bits



## **Note**

1. If logic 1s are written to PD and IDL at the same time, PD takes precedence. The reset value of PCON is (0XX00000).

## **4.16 Oscillator circuitry**

The on-chip amplitude controlled oscillator circuitry is a single-stage inverting amplifier biased by an internal feedback resistor  $R_{\text{fb}}$ . The oscillator circuit is shown in Fig.38. When using a quartz crystal to drive the oscillator, no external components are needed. When using an external ceramic resonator to drive the oscillator, external components may be required depending upon the ceramic resonator specifications (refer to specific product specification). Two different configurations are shown in Fig.39(a) and Fig.39(b).

To drive the device with an external clock source, apply the external clock signal to XTAL1, and leave XTAL2 to float, as shown in Fig.39(c).

If the amplitude of the input signal is less than  $V_{DD}$  to  $V_{SS}$ or a sine wave is applied, capacitive decoupling is needed as shown in Fig.39(d).

In the Power-down mode the oscillator is stopped and XTAL1 and XTAL2 are internally pulled LOW. The current of the whole oscillator is switched off (signals ENABLECUR and ENABLECLK are inactive).

The system clock can be made available on a port pin by setting the ECLK bit in the ALTP register (see Section 4.10.4). This is useful in applications where the system clock of the microcontroller is used to clock other ICs. In this case the port latch of the port pin should be set to a logic 1 in order to avoid conflict between the system clock output and the port output.





# **4.17 Reset**

To initialize the TELX microcontroller a reset is performed by one of three methods:

- Applying an external signal to the RST pin
- Via internal Power-on reset circuitry
- Via the on-chip Watchdog Timer.

The state of the port pins after a reset is given in the respective product specification.

The RST pin can function as an input or output pin. As an output pin it can be used to reset other IC's.

The internal RAM and the EEPROM are not affected by reset. When  $V_{DD}$  is turned on, the RAM contents are indeterminate.

## 4.17.1 EXTERNAL RESET USING THE RST PIN

The external reset input for the TELX microcontroller is the RST pin, it is asynchronous to the internal clock. A Schmitt trigger is used at the input for noise rejection. Immediately after the RST goes LOW the CPU responds by executing an internal reset, the SFRs and port pins adopt their reset state, ALE and PSEN are held HIGH. As long as RST pin remains LOW, the slot generator is halted at timeslot 1 and the reset state is maintained. When RST goes HIGH, the slot generator is started and program execution starts after 2 machine cycles.

4.17.2 EXTERNAL POWER-ON RESET USING THE RST PIN

An automatic reset can be obtained by connecting the RST pin to  $V_{SS}$  via a capacitor. At power-on, the voltage on the RST pin is equal to  $V_{SS}$  and increases from  $V_{SS}$  as the capacitor charges through the internal resistor  $(R_{RST})$  to  $V_{DD}$ .  $V_{RST}$  must remain below the higher threshold of the Schmitt trigger long enough for the oscillator to become stable. The time required is approximately 1024 oscillator periods. The reset configuration is shown in Fig.40.

# 4.17.3 INTERNAL POWER-ON/POWER-OFF RESET (POR)

The device contains an on-chip Power-on-reset circuit which activates a reset as long as  $V_{DD}$  is below a predefined level ( $V_{PORH}$ ). If  $V_{DD}$  exceeds  $V_{PORH}$ , the oscillator will start-up. However, to ensure that the oscillator is stable before the controller starts, the clock signals are gated away from the CPU for 1024 oscillator periods.After this delay the slot generator is started and program execution starts after 2 machine cycles.

The Power-on-reset circuit also ensures, that the microcontroller will be switched-off as soon as a second predefined level ( $V_{PORL}$ ) is reached as  $V_{DD}$  decreases.

The on-chip POR circuit can also be switched off by connecting the PORACTIVE pin to  $V_{SS}$ . This reduces the Power-down current even further and can be chosen if external reset circuitry is used.

If the POR signal is active, the RST pin will be pulled LOW.

The state of internal registers after a reset are given in the product specifications.

## 4.17.4 TRIP POINTS OF POR (POWER-ON/OFF-RESET)

At power-up or at varying supply voltage, the POR circuit will ensure that the microcontroller is reset correctly at predefined levels. The POR trip points are defined as follows:

- POR trip level HIGH ( $V_{\text{PORH}}$ ). When this level is reached at rising  $V_{DD}$ , the internal reset signal is deactivated (oscillator released and CPU released after a delay of 1024 or 32 clock periods).
- POR trip level LOW ( $V_{\text{PORL}}$ ). When this level is reached at falling  $V_{DD}$ , the internal reset signal is activated (oscillator stopped).

The minimum  $V_{DD}$  for the microcontroller depends on the clock frequency used.

Eight different voltages for trip level HIGH ( $V_{\mathsf{PORH}}$ ) can be chosen. The hysteresis  $V_{PORH} - V_{PORL}$  can be chosen either to be fixed at a level relative to  $V_{PORH}$ , typically 100 mV (so  $V_{PORL}$  will be  $V_{PORH}$  – 100 mV), or at a very low value typically at 1.3 V. Any combination of a  $V_{PORH}$ option and a hysteresis option can be chosen. The chosen option for the trip levels and the type of hysteresis can be checked by reading the Reset Status Register (RSTAT); see Section 4.17.5.

The hysteresis option with  $V_{PORL} = 1.3$  V is foreseen for the case when no reset is wanted when  $V_{DD}$  is decreasing below minimum  $V_{DD}$  (operating) but still being above minimum  $V_{DD}$  (RAM retention).





4.17.5 RESET STATUS REGISTER (RSTAT)

This 8-bit register gives the chosen reset option for the POR circuit and for the on-chip oscillator.

**Table 87** Reset Status register RSTAT (SFR address E6H)



## **Table 88** Description of RSTAT bits



## **Table 89** POR trip points



## 4.17.6 INTERNAL RESET VIA THE WATCHDOG

The Watchdog which is available on the RST pin is described in Section 4.8.3.

# **4.18** Low Voltage Detection

The Low Voltage Detection (LVD) is a feature which can be used to determine if a certain voltage level of  $V_{DD}$  has been reached, e.g. low voltage warning for EEPROM or DTMF operation, or for normal operation. The LVD is programmed by software via the LVD Control Register (LVDCON).

An active output from the Low Voltage Detection block will set the LVDI bit in the LVD Control Register, this can be detected by software, and an internal interrupt will be generated providing the ELVD bit in the IEN2 register is set. The LVDI bit must be reset by software. The LVD interrupt can be activated on a rising or falling edge of  $V_{DD}$ . The selection is made using the LVDX bit in the LVDCON register.

The state of the LVD signal is indicated by the LVDS bit in LVDCON. LVDS can only be read.

The LVD can also be used to enter and exit the Power-down mode automatically without first setting the PD bit in the PCON register. This feature is further described in Section 4.18.2.

Programming of the LVD trip points is done by software for both the OTP and ROM versions, via the LVDCON register. The trip levels can be changed any time during program execution. Ten different options for the high trip level  $(V_{LVDH})$  plus an option 'Off' for power saving are offered. The hysteresis between the high and low trip points (V<sub>LVDH</sub> – V<sub>LVDL</sub>) is typically 100 mV. The various options are listed in Table 92.

The variation of the different trip points for POR and LVD are related as both blocks use the same on-chip bandgap reference. The levels of the POR and LVD trip points should be programmed to be in the following order:  $V_{LVDH}$  >  $V_{LVDL}$  >  $V_{PORH}$  >  $V_{PORL}$  (refer to Fig.41).



## 4.18.1 LVD CONTROL REGISTER (LVDCON)

## **Table 90** LVD Control Register (SFR address F2H)



## **Table 91** Description of LVDCON bits



## **Table 92** Selection and levels of the LVD trip points



### 4.18.2 Entering and exiting Power-down mode automatically using LVD.

The TELX family offers the feature of entering the Power-down mode automatically, without any external voltage detector, see Fig.43. If the LVDPEN bit in the LVDCON register is set, the TELX microcontroller will enter the Power-down mode automatically as soon as the low LVD trip level  $(V_{LVDL})$  is reached when the supply voltage decreases. This is useful when the Power-down mode must be entered quickly before the  $V_{DD(min)}$  level is reached.

The trip point for  $V_{LVDL}$  is set by software as described in Section 4.18. Exit from Power-down mode is done either via a reset, or when the high LVD trip level  $(V_{LVDH})$  is reached when the supply voltage rises.

## 4.18.3 Entering and exiting Power-down mode explicitly, using an LVD interrupt.

The Power-down mode can also be entered via an interrupt generated by the LVD and a corresponding interrupt software routine. In the interrupt routine, actions such as saving data in EEPROM or displaying a warning could be taken before entering the Power-down mode by setting LVDPEN. If  $V_{DD}$  rises above  $V_{LVDH}$ , the microcontroller exits the Power-down mode and resumes program execution inside the interrupt routine, see Fig.44.

Note that the next instruction after setting the LVDPEN bit will be executed before the microcontroller enters the Power-down mode. If this is not wanted, a NOP instruction should be inserted directly after the instruction setting the LVDPEN bit.





## **5 INSTRUCTION SET**

The TELX Family uses a powerful instruction set which permits the expansion of on-chip CPU peripherals and optimizes byte efficiency and execution speed. Assigned opcodes add new high-power operation and permit new addressing modes. The instruction set consists of 49 single-byte, 46 two-byte and 16 three-byte instructions. When using a 3.58 MHz oscillator, 64 instructions execute in 1.68 µs and 45 instructions execute in 3.35 µs. Multiply and divide instructions execute in 6.70 µs.



## **Table 93** Instruction Set











## **Table 95** Hexadecimal opcode cross-reference



Philips Semiconductors

# Low voltage 8-bit microcontrollers Low voltage 8-bit microcontrollers TELX family



 $^{14}$  MOV A, ACC is not a valid instruction.

**TELX family** 

# **6 DEFINITIONS**



## **7 LIFE SUPPORT APPLICATIONS**

These products are not designed for use in life support appliances, devices, or systems where malfunction of these products can reasonably be expected to result in personal injury. Philips customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Philips for any damages resulting from such improper use or sale.

# **8 PURCHASE OF PHILIPS I2C COMPONENTS**



Purchase of Philips I<sup>2</sup>C components conveys a license under the Philips' I<sup>2</sup>C patent to use the components in the  $12C$  system provided the system conforms to the  $12C$  specification defined by Philips. This specification can be ordered using the code 9398 393 40011.

**NOTES**

**NOTES**

**NOTES**

# **Philips Semiconductors – a worldwide company**

**Argentina:** see South America **Australia:** 34 Waterloo Road, NORTH RYDE, NSW 2113, Tel. +61 2 9805 4455, Fax. +61 2 9805 4466 **Austria:** Computerstr. 6, A-1101 WIEN, P.O. Box 213, Tel. +43 1 60 101, Fax. +43 1 60 101 1210 **Belarus:** Hotel Minsk Business Center, Bld. 3, r. 1211, Volodarski Str. 6, 220050 MINSK, Tel. +375 172 200 733, Fax. +375 172 200 773 **Belgium:** see The Netherlands **Brazil:** see South America **Bulgaria:** Philips Bulgaria Ltd., Energoproject, 15th floor, 51 James Bourchier Blvd., 1407 SOFIA, Tel. +359 2 689 211, Fax. +359 2 689 102 **Canada:** PHILIPS SEMICONDUCTORS/COMPONENTS, Tel. +1 800 234 7381 **China/Hong Kong:** 501 Hong Kong Industrial Technology Centre, 72 Tat Chee Avenue, Kowloon Tong, HONG KONG, Tel. +852 2319 7888, Fax. +852 2319 7700 **Colombia:** see South America **Czech Republic:** see Austria **Denmark:** Prags Boulevard 80, PB 1919, DK-2300 COPENHAGEN S, Tel. +45 32 88 2636, Fax. +45 31 57 0044 **Finland:** Sinikalliontie 3, FIN-02630 ESPOO, Tel. +358 9 615800, Fax. +358 9 61580920 **France:** 4 Rue du Port-aux-Vins, BP317, 92156 SURESNES Cedex, Tel. +33 1 40 99 6161, Fax. +33 1 40 99 6427 **Germany:** Hammerbrookstraße 69, D-20097 HAMBURG, Tel. +49 40 23 53 60, Fax. +49 40 23 536 300 **Greece:** No. 15, 25th March Street, GR 17778 TAVROS/ATHENS, Tel. +30 1 4894 339/239, Fax. +30 1 4814 240 **Hungary:** see Austria **India:** Philips INDIA Ltd, Shivsagar Estate, A Block, Dr. Annie Besant Rd. Worli, MUMBAI 400 018, Tel. +91 22 4938 541, Fax. +91 22 4938 722 **Indonesia:** see Singapore **Ireland:** Newstead, Clonskeagh, DUBLIN 14, Tel. +353 1 7640 000, Fax. +353 1 7640 200 **Israel:** RAPAC Electronics, 7 Kehilat Saloniki St, PO Box 18053, TEL AVIV 61180, Tel. +972 3 645 0444, Fax. +972 3 649 1007 **Italy:** PHILIPS SEMICONDUCTORS, Piazza IV Novembre 3, 20124 MILANO, Tel. +39 2 6752 2531, Fax. +39 2 6752 2557 **Japan:** Philips Bldg 13-37, Kohnan 2-chome, Minato-ku, TOKYO 108, Tel. +81 3 3740 5130, Fax. +81 3 3740 5077 **Korea:** Philips House, 260-199 Itaewon-dong, Yongsan-ku, SEOUL, Tel. +82 2 709 1412, Fax. +82 2 709 1415

**Malaysia:** No. 76 Jalan Universiti, 46200 PETALING JAYA, SELANGOR, Tel. +60 3 750 5214, Fax. +60 3 757 4880

**Mexico:** 5900 Gateway East, Suite 200, EL PASO, TEXAS 79905, Tel. +9-5 800 234 7381

**Middle East:** see Italy

**Netherlands:** Postbus 90050, 5600 PB EINDHOVEN, Bldg. VB, Tel. +31 40 27 82785, Fax. +31 40 27 88399

**New Zealand:** 2 Wagener Place, C.P.O. Box 1041, AUCKLAND, Tel. +64 9 849 4160, Fax. +64 9 849 7811

**Norway:** Box 1, Manglerud 0612, OSLO, Tel. +47 22 74 8000, Fax. +47 22 74 8341

**Philippines:** Philips Semiconductors Philippines Inc., 106 Valero St. Salcedo Village, P.O. Box 2108 MCC, MAKATI, Metro MANILA, Tel. +63 2 816 6380, Fax. +63 2 817 3474

**Poland:** Ul. Lukiska 10, PL 04-123 WARSZAWA, Tel. +48 22 612 2831, Fax. +48 22 612 2327

**Portugal:** see Spain

**Romania:** see Italy

**Russia:** Philips Russia, Ul. Usatcheva 35A, 119048 MOSCOW, Tel. +7 095 755 6918, Fax. +7 095 755 6919

**Singapore:** Lorong 1, Toa Payoh, SINGAPORE 1231, Tel. +65 350 2538, Fax. +65 251 6500

**Slovakia:** see Austria

**Slovenia:** see Italy

**South Africa:** S.A. PHILIPS Pty Ltd., 195-215 Main Road Martindale, 2092 JOHANNESBURG, P.O. Box 7430 Johannesburg 2000, Tel. +27 11 470 5911, Fax. +27 11 470 5494

**South America:** Rua do Rocio 220, 5th floor, Suite 51, 04552-903 São Paulo, SÃO PAULO - SP, Brazil, Tel. +55 11 821 2333, Fax. +55 11 829 1849

**Spain:** Balmes 22, 08007 BARCELONA, Tel. +34 3 301 6312, Fax. +34 3 301 4107

**Sweden:** Kottbygatan 7, Akalla, S-16485 STOCKHOLM, Tel. +46 8 632 2000, Fax. +46 8 632 2745

**Switzerland:** Allmendstrasse 140, CH-8027 ZÜRICH, Tel. +41 1 488 2686, Fax. +41 1 481 7730

**Taiwan:** Philips Semiconductors, 6F, No. 96, Chien Kuo N. Rd., Sec. 1, TAIPEI, Taiwan Tel. +886 2 2134 2865, Fax. +886 2 2134 2874

**Thailand: PHILIPS ELECTRONICS (THAILAND) Ltd.** 209/2 Sanpavuth-Bangna Road Prakanong, BANGKOK 10260, Tel. +66 2 745 4090, Fax. +66 2 398 0793

**Turkey:** Talatpasa Cad. No. 5, 80640 GÜLTEPE/ISTANBUL, Tel. +90 212 279 2770, Fax. +90 212 282 6707

**Ukraine**: PHILIPS UKRAINE, 4 Patrice Lumumba str., Building B, Floor 7, 252042 KIEV, Tel. +380 44 264 2776, Fax. +380 44 268 0461

**United Kingdom:** Philips Semiconductors Ltd., 276 Bath Road, Hayes, MIDDLESEX UB3 5BX, Tel. +44 181 730 5000, Fax. +44 181 754 8421

**United States:** 811 East Arques Avenue, SUNNYVALE, CA 94088-3409, Tel. +1 800 234 7381

**Uruguay:** see South America

**Vietnam:** see Singapore

**Yugoslavia:** PHILIPS, Trg N. Pasica 5/v, 11000 BEOGRAD, Tel. +381 11 625 344, Fax.+381 11 635 777

**For all other countries apply to:** Philips Semiconductors, Marketing & Sales Communications, Building BE-p, P.O. Box 218, 5600 MD EINDHOVEN, The Netherlands, Fax. +31 40 27 24825

**Internet:** http://www.semiconductors.philips.com

© Philips Electronics N.V. 1997 SCA54

All rights are reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner. The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without notice. No liability will be accepted by the publisher for any consequence of its use. Publication thereof does not convey nor imply any license under patent- or other industrial or intellectual property rights.

Printed in The Netherlands 457047/00/01/pp92 Date of release: 1997 Jul 02 Document order number: 9397 750 02551

**PHILIPS** 

Let's make things better.

**Philips Semiconductors** 

